^) Express Mail No. EL 750739031 US 



CLAIMS: 

What is claimed is: 

1 . A method for removing the effect of clock skew between data processing systems, 
comprising: 

making delay measurements between two data processing systems connected by a 
network; 

forming a set of data points, wherein each data point in the set of data points comprises a 
time and a delay measurement for the respective time; 

finding a convex hull of the set of data points, wherein the convex hull is bounded by a 
number of line segments; 

selecting a one of the line segments that optimizes an objective function; 

extrapolating the one of the line segments to obtain an affine function; and 

removing the effect of clock skew between the two data processing systems as 
characterized by the affine function. 

2. The method of claim 1, wherein the one of the line segments is selected so that a line 
containing the one of the line segments will contain a maximal number of data points 
from the set of data points. 
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3. The method of claim 1, wherein the one of the line segments is selected so that the sum 
of the vertical distances between each of the set of data points and a line containing the 
one of the line segments will be minimized. 

5 4. The method of claim 3, wherein selecting the one of the line segments includes: 

calculating an arithmetic mean of x-coordinates of all of the set of data points; and 

selecting a one of the line segments that contains a point whose x-coordinate is equal to 
1 0 the arithmetic mean. 

5. The method of claim 1, wherein the one of the line segments is selected so that the area 
between a plot of a piecewise-linear function containing the set of data points and a line 
containing the one of the line segments will be minimized. 

15 

6. The method of claim 5, wherein selecting the one of the line segments includes: 

calculating an arithmetic mean of an x-coordinate of a first data point and an x-coordinate 
of a second data point, wherein the x-coordinate of the first data point is the lowest of any 
20 data point in the set of data points, and wherein the x-coordinate of the second data point 
is the greatest of any data point in the set of data points; and 

selecting a one of the line segments that contains a point whose x-coordinate is equal to 
the arithmetic mean. 

25 

7. The method of claim 1, wherein the x-coordinate of each data point in the set of data 
points represents a time measurement. 
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8. The method of claim 1, wherein the y-coordinate of each data point in the set of data 
points represents a delay measurement. 

5 9. The method of claim 8, wherein the delay measurement is a communication delay 
between two data processing systems connected by a network. 

10. A computer program product, in a computer-readable medium, for removing the 
effect of clock skew between data processing systems, comprising instructions for: 



making a delay measurement between two data processing systems connected by a 
network; 



Ly forming a set of data points, wherein each data point in the set of data points comprises a 

1 5 time and a delay measurement for the respective time; 

finding a convex hull of the set of data points, wherein the convex hull is bounded by a 
number of line segments; 

20 selecting a one of the line segments that optimizes an objective function; 



extrapolating the one of the line segments to obtain an affine function; and 

removing the effect of clock skew between the two data processing systems as 
25 characterized by the affine function. 
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11. The computer program product of claim 10, wherein the one of the line segments is 
selected so that a line containing the one of the line segments will contain a maximal 
number of data points from the set of data points. 

12. The computer program product of claim 10, wherein the one of the line segments is 
selected so that the sum of the vertical distances between each of the set of data points 
and a line containing the one of the line segments will be minimized. 

13. The computer program product of claim 12, wherein the instructions for selecting the 
one of the line segments include instructions for: 

calculating an arithmetic mean of x-coordinates of all of the set of data points; and 

selecting a one of the line segments that contains a point whose x-coordinate is equal to 
the arithmetic mean. 

14. The computer program product of claim 10, wherein the one of the line segments is 
selected so that the area between a plot of a piecewise-linear function containing the set 
of data points and a line containing the one of the line segments will be minimized. 

15. The computer program product of claim 14, wherein the instructions for selecting the 
one of the line segments include instructions for: 

calculating an arithmetic mean of an x-coordinate of a first data point and an x-coordinate 
of a second data point, wherein the x-coordinate of the first data point is the lowest of any 
data point in the set of data points, and wherein the x-coordinate of the second data point 
is the greatest of any data point in the set of data points; and 
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selecting a one of the line segments that contains a point whose x-coordinate is equal to 
the arithmetic mean. 

5 16. The computer program product of claim 10, wherein the x-coordinate of each data 
point in the set of data points represents a time measurement. 

17. The computer program product of claim 10, wherein the y-coordinate of each data 
point in the set of data points represents a delay measurement. 

10 

18. The computer program product of claim 17, wherein the delay measurement is a 
communication delay between two data processing systems connected by a network. 

19. A data processing system for removing the effect of clock skew between data 
1 5 processing systems, comprising: 

a bus system; 

a processing unit connected to the bus system, wherein the processing unit contains at 
20 least one processor; 

a memory connected to the bus system; and 

a set of instructions, 

25 

wherein the processing unit executes the set of instructions to perform the acts of: 
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making a delay measurement between two data processing systems connected by a 
network; 

forming a set of data points, wherein each data point in the set of data points comprises a 
time and a delay measurement for the respective time; 

finding a convex hull of the set of data points, wherein the convex hull is bounded by a 
number of line segments; 

selecting a one of the line segments that optimizes an objective function; and 

extrapolating the one of the line segments to obtain an affine function; and 

removing the effect of clock skew between the two data processing systems as 
characterized by the affine function. 

20. The data processing system of claim 19, wherein the one of the line segments is 
selected so that a line containing the one of the line segments will contain a maximal 
number of data points from the set of data points. 

21. The data processing system of claim 19, wherein the one of the line segments is 
selected so that the sum of the vertical distances between each of the set of data points 
and a line containing the one of the line segments will be minimized. 

22. The data processing system of claim 21, wherein the act of selecting the one of the 
line segments includes: 
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calculating an arithmetic mean of x-coordinates of all of the set of data points; and 

selecting a one of the line segments that contains a point whose x-coordinate is equal to 
the arithmetic mean. 

5 

23. The data processing system of claim 19, wherein the one of the line segments is 
selected so that the area between a plot of a piecewise-linear function containing the set 
of data points and a line containing the one of the line segments will be minimized. 

10 24. The data processing system of claim 23, wherein the act of selecting the one of the 
line segments includes: 



calculating an arithmetic mean of an x-coordinate of a first data point and an x-coordinate 
of a second data point, wherein the x-coordinate of the first data point is the lowest of any 
15 data point in the set of data points, and wherein the x-coordinate of the second data point 



selecting a one of the line segments that contains a point whose x-coordinate is equal to 
the arithmetic mean. 

20 

25. The data processing system of claim 19, wherein the x-coordinate of each data point 
in the set of data points represents a time measurement. 

26. The data processing system of claim 19, wherein the y-coordinate of each data point 
25 in the set of data points represents a delay measurement. 



is the greatest of any data point in the set of data points; and 



Docket No. YOR920000760US 1 

23 



Express Mail No, EL 750739031 US 



27. The data processing system of claim 26, wherein the delay measurement is a 
communication delay between two data processing systems connected by a network. 
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